[[...path]].page.tsx 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. import {
  2. NextPage, GetServerSideProps, GetServerSidePropsContext,
  3. } from 'next';
  4. import { useTranslation } from 'next-i18next';
  5. import dynamic from 'next/dynamic';
  6. import { useRouter } from 'next/router';
  7. import AdminHome from '~/components/Admin/AdminHome/AdminHome';
  8. import AppSettingsPageContents from '~/components/Admin/App/AppSettingsPageContents';
  9. import DataImportPageContents from '~/components/Admin/ImportData/ImportDataPageContents';
  10. import MarkDownSettingContents from '~/components/Admin/MarkdownSetting/MarkDownSettingContents';
  11. import UserGroupPage from '~/components/Admin/UserGroup/UserGroupPage';
  12. import UserManagement from '~/components/Admin/UserManagement';
  13. import AdminLayout from '~/components/AdminLayout';
  14. import { CrowiRequest } from '~/interfaces/crowi-request';
  15. import { CommonProps, getServerSideCommonProps, useCustomTitle } from '~/pages/commons';
  16. import PluginUtils from '~/server/plugins/plugin-utils';
  17. import ConfigLoader from '~/server/service/config-loader';
  18. // import SecurityManagementContents from '~/components/Admin/Security/SecurityManagementContents';
  19. // import ExportArchiveDataPage from '~/components/Admin/ExportArchiveDataPage';
  20. // import ElasticsearchManagement from '~/components/Admin/ElasticsearchManagement/ElasticsearchManagement';
  21. import {
  22. useCurrentUser,
  23. /* useSearchServiceConfigured, useSearchServiceReachable, */ useSiteUrl,
  24. } from '~/stores/context';
  25. // import { useEnvVars } from '~/stores/admin-context';
  26. const pluginUtils = new PluginUtils();
  27. type Props = CommonProps & {
  28. currentUser: any,
  29. nodeVersion: string,
  30. npmVersion: string,
  31. yarnVersion: string,
  32. installedPlugins: any,
  33. envVars: any,
  34. isSearchServiceConfigured: boolean,
  35. isSearchServiceReachable: boolean,
  36. siteUrl: string,
  37. };
  38. const AdminMarkdownSettingsPage: NextPage<Props> = (props: Props) => {
  39. const { t } = useTranslation();
  40. const router = useRouter();
  41. const path = router.query.path || 'home';
  42. const name = Array.isArray(path) ? path[0] : path;
  43. // const CustomizeSettingContents = dynamic(() => import('../../components/Admin/Customize/Customize'), { ssr: false });
  44. const adminPagesMap = {
  45. home: {
  46. title: useCustomTitle(props, t('Wiki Management Home Page')),
  47. component: <AdminHome
  48. nodeVersion={props.nodeVersion}
  49. npmVersion={props.npmVersion}
  50. yarnVersion={props.yarnVersion}
  51. installedPlugins={props.installedPlugins}
  52. />,
  53. },
  54. app: {
  55. title: useCustomTitle(props, t('App Settings')),
  56. component: <AppSettingsPageContents />,
  57. },
  58. security: {
  59. title: useCustomTitle(props, t('security_settings')),
  60. // component: <SecurityManagementContents />,
  61. component: <>SecurityManagementContents</>,
  62. },
  63. markdown: {
  64. title: useCustomTitle(props, t('Markdown Settings')),
  65. component: <MarkDownSettingContents />,
  66. // component: <>MarkDownSettingContents</>,
  67. },
  68. customize: {
  69. title: useCustomTitle(props, t('Customize Settings')),
  70. // component: <CustomizeSettingContents />,
  71. component: <>CustomizeSettingContents</>,
  72. },
  73. importer: {
  74. title: useCustomTitle(props, t('Import Data')),
  75. component: <DataImportPageContents />,
  76. },
  77. export: {
  78. title: useCustomTitle(props, t('Export Archive Data')),
  79. // component: <ExportArchiveDataPage />,
  80. component: <>ExportArchiveDataPage</>,
  81. },
  82. notification: {
  83. title: useCustomTitle(props, t('Notification Settings')),
  84. component: <>notification</>,
  85. },
  86. 'global-notification': {
  87. title: '',
  88. component: <>global-notification</>,
  89. },
  90. users: {
  91. title: useCustomTitle(props, t('User_Management')),
  92. // component: <UserManagement />,
  93. component: <>UserManagement</>,
  94. },
  95. 'user-groups': {
  96. title: useCustomTitle(props, t('UserGroup Management')),
  97. component: <>user-groups</>,
  98. },
  99. search: {
  100. title: useCustomTitle(props, t('Full Text Search Management')),
  101. // component: <ElasticsearchManagement />,
  102. component: <>ElasticsearchManagement</>,
  103. },
  104. };
  105. const content = adminPagesMap[name];
  106. const title = content.title;
  107. useCurrentUser(props.currentUser != null ? JSON.parse(props.currentUser) : null);
  108. // useSearchServiceConfigured(props.isSearchServiceConfigured);
  109. // useSearchServiceReachable(props.isSearchServiceReachable);
  110. useSiteUrl(props.siteUrl);
  111. // useEnvVars(props.envVars);
  112. return (
  113. <AdminLayout title={title} selectedNavOpt={name}>
  114. {content.component}
  115. </AdminLayout>
  116. );
  117. };
  118. export const getServerSideProps: GetServerSideProps = async(context: GetServerSidePropsContext) => {
  119. const req: CrowiRequest = context.req as CrowiRequest;
  120. const { crowi } = req;
  121. const {
  122. appService, searchService,
  123. } = crowi;
  124. const { user } = req;
  125. const result = await getServerSideCommonProps(context);
  126. // check for presence
  127. // see: https://github.com/vercel/next.js/issues/19271#issuecomment-730006862
  128. if (!('props' in result)) {
  129. throw new Error('invalid getSSP result');
  130. }
  131. const props: Props = result.props as Props;
  132. if (user != null) {
  133. // props.currentUser = JSON.stringify(user.toObject());
  134. props.currentUser = JSON.stringify(user);
  135. }
  136. props.siteUrl = appService.getSiteUrl();
  137. props.nodeVersion = crowi.runtimeVersions.versions.node ? crowi.runtimeVersions.versions.node.version.version : null;
  138. props.npmVersion = crowi.runtimeVersions.versions.npm ? crowi.runtimeVersions.versions.npm.version.version : null;
  139. props.yarnVersion = crowi.runtimeVersions.versions.yarn ? crowi.runtimeVersions.versions.yarn.version.version : null;
  140. props.installedPlugins = pluginUtils.listPlugins();
  141. props.envVars = await ConfigLoader.getEnvVarsForDisplay(true);
  142. props.isSearchServiceConfigured = searchService.isConfigured;
  143. props.isSearchServiceReachable = searchService.isReachable;
  144. return {
  145. props,
  146. };
  147. };
  148. export default AdminMarkdownSettingsPage;